<template>
  <input type="text" v-model="keyWord" name="" id="" />
  <h2>{{ keyWord }}</h2>
</template>

<script>
import { ref, customRef } from 'vue'
export default {
  name: 'App',
  setup() {
    // 自定义ref
    function myRef(value, delay) {
      let timer
      return customRef((track, trigger) => {
        return {
          get() {
            track() //通知vue追踪value的变化
            return value
          },
          set(newValue) {
            console.log(newValue)
            clearTimeout(timer)
            timer = setTimeout(() => {
              value = newValue
              trigger() // 通知vue去重新解析模板
            }, delay)
          }
        }
      })
      // console.log('---myRef---', value)
    }

    // let keyWord = ref('hello')  使用vue提供的ref
    let keyWord = myRef('hello', 500) // 使用程序员自定义的ref
    return {
      keyWord
    }
  }
}
</script>
